package com.zzyl.mapper;

import com.github.pagehelper.Page;
import com.zzyl.dto.DeviceDto;
import com.zzyl.entity.Device;
import com.zzyl.vo.DeviceDataGraphVo;
import com.zzyl.vo.DeviceVo;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;

import java.time.LocalDateTime;
import java.util.List;

@Mapper
public interface DeviceMapper {
    /**
     * 通过设备名查询设备信息
     */
    Integer queryDeviceName(String deviceName);

    /**
     * 新增设备到本地数据库
     */
    void insert(Device device);

    /**
     * 分页查询设备列表
     */
    Page<DeviceVo> pageQuery(DeviceDto deviceDto);

    /**
     * 删除数据库的设备信息
     */
    void deleteDevice(String iotId, String productKey);

    /**
     * 查询设备详细数据
     */
    Device QueryDeviceDetail(DeviceDto deviceDto);

    /**
     * 修改设备备注名称
     */
    void updateDevice(DeviceDto deviceDto);

    /**
     * 查询设备信息
     */
    @Select("select * from device where iot_id=#{iotId}")
    Device queryByIotId(String iotId);

    /**
     * 查询统计数据(天)
     */
    List<DeviceDataGraphVo> queryDeviceDataListByDay(String iotId, String functionId, LocalDateTime start, LocalDateTime end);

    /**
     * 查询统计数据（周）
     */
    List<DeviceDataGraphVo> queryDeviceDataListByWeek(String iotId, String functionId, LocalDateTime start, LocalDateTime end);

    /**
     * 根据老人随身绑定设备ID查询护理人员列表
     */
    public List<Long> queryNursingIdsByIotIdWithElder(String iotId);

    /**
     * 根据老人绑定床位的设备ID查询护理人员列表
     */
    public List<Long> queryNursingIdsByIotIdWithBed(String iotId);
}
